]حول 11× الجزء الثاني[ 


موضعح اليوم حول: 
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]حول 1× الجزء الثاني[ 


بسم الله الرحمن الرحيم 


و الصلاة و السلام على أشرف المرسلين سيدنا محمد خاتم الأنبياء و المرسلين 


أما بعد 


ج: "سين جيم" هي سلسلة من المواضيع الخفيفة و الهامة لكل مبرمج. إذ أننا في كل مرة سنتناول فكرة معينة 
مبدأ معين» تعريف معين» و يكون من الأمور التي تصادفنا كمبرمجين مع محاولة التركيز على الشرح و مبداأ 
العمل و خطوات الاستعمال بالترتيب في حين سنحاول قدر الإمكان استعمال الخطوات بدل الأكواد لتفادي 
التعارض بين اللغات. آما في حالة كانت هناك ضرورة تستدعي استخدام الأكواد البرمجية للغة معينة 


أتمنى أن تنال السلسلة رضاكم و أرجو أن لا تبخلوا علي بأي سؤال يعتريكم في أمر من أمور البرمجة كي 
أضعه في موضوع بإذن الله ليستفيد الجميع. و أجري و أجركم على الله و الله من وراء المقصد. 


أخوكم سمير علوي 
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سلسلة "سين؟... جيم" ٠‏ ]حول 11× الجزء الثاني[ 


ج: موضوع اليوم هو تكملة للموضوع الذي بدأناه سابقا و هو موضوع 1 ×. فبعد أن تحدثنا عن الشكل العام 
له. سنتحدث اليوم عن القيم و كيف تمتل و كيف تحفظ بين الوسوم أو في متغيرات. 


ج: كما قلنا سابقا فإن 01× بنية خاملة و ليس كائنا نشيطا فهو يحفظ القيم فقط و القيم التي يحفظها تكون من 
الأنواع البسيطة و هي إما قيم رقمية و إما قيم حرفية. و لا يمكنه أن يحفظ قيما بشكل آخر مثل الألوان أو 


نی 4 


mmm mmm HHNRNRNHHRHRNNHNHNNNNHHNHNNNHNHHNNHNHNHNNNHNHNNNNNHNNNNNHHNNNNNDGNNNHNNNRNMRNRNRNRNRNRNR MANN NHNHNNNHHNNHNNNNHNHNNNNNHNHNNNHNHNNNNHNNNNHHNNNNHHNNNNNNHNHNNNNRNNNNRNNNNNNNNNNHHNNNNNNNNNHHNNNNRNRNNRNNRNEN 


ج: الأمر بسيط جدا. هذه الأشياء يتم تمثيل قيمها المركبة بقيم بسيطة حرفية أو رقمية. و سواء يتم ذلك آليا أو يدويا 


سنام 4 


ه٠‏ النوع المنطقي ٣"‏ هءامهم8" يتم تمثيل القيمة "صح" بالكلمة مں,] و القيمة "خطأ" بالكلمة مءإه؟ فالتمثيل هنا 
يكون آليا سواء عند الكتابة في ملف امم» أو القراءة منه 
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ه التعدادات: في العادة التعدادات هي بنية بها مجموعة من الثوابت التي تكون قيمها أعدادا تامة أي أنها لا 
تحتوي أرقاما عشرية. فالمتغيرات من هذا النوع يتم حفظ اسمها بدل قيمتها في ملف .× فنأخذ مثالا بتعريف 


تعداد جديد ثم نعرف متغير من ذلك التعداد و نعطيه قيمة. 
i Enum DayNames As Byte ۰‏ 
Saturday‏ 
Sunday‏ 
Monday‏ 
Tusday‏ 
Wednesday = 4‏ 
Thursday = 5‏ 
Friday = 6‏ 
ı End Enum‏ 
ı' Dim x As DayNames = DayNames.Monday‏ 


wr 


NEH 
کم ل۸ لا‎ || 


sansa 


يمكننا ملاحظة أن النوع المنطقي في الحقيقة ما هو إلا تعداد حيث القيمة 0 تعني خطأً و أي قيمة تختلف عن 


٠‏ التاريخ: التاريخ نوع مركب من حقول هي: السنوات» الأشهر» الأيام» الساعات» الدقائق» الثوانيء الأجزاء 
من الألف من الثانية و هي كلها أعداد تامة موجبة و هي بذلك قابلة للتحويل الآلي غير أن ا× لا يحفظها 
كحقول بل بشكل جملة يبدأ فيها بالسنوات تم الأشهر تم الأيام بينها علامة "-" (ناقص). تم يأتي حرف "1" 
بمعنى ۲"٠.‏ و يكتب بعدها الساعات ثم الدقائق ثم الثواني بينها الرمز ٠":"‏ ثم الأجزاء من الألف من الثانية و 
بليها الفارق الزمني عن خط غرينيتش., فلو أردت تمثيل الوقت الحالي باستعمال الدالة سه" فالنتيجة |ا× 


sansnssansmsnssmamsssmnmamsmamammsmammmamammmmammmmamMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMnan, 


ه الهياكل: و هي نوع مركب من عدة حقول يشبه الكلاس في كثير من الأمور و هو ما نسميه 
Enregistrement‏ حيث يتوجب علينا تعريف قيم الحقول للمتغير من هذا النوع بالشكل "متغير .حقل-قيمة" 
عندما تكون الحقول من آنواع بسيطة أو قابلة للتحويل الآلي أو تم التعامل مع تحويلها يدويا فسيكون حفظ 
ا 


ك مثالا E‏ کان نعری هھیکلا جدبدا هو "۶٥۲0۸0٥"‏ له إسم و لقب و عمر و جنس. و لأجل الحقل 
ا ل ل ل ll ll‏ 
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Enum Gender As Byte 
Male = 0 
Female = 

End Enum 


1 


Structure Personne 
Dim Nom As String 
Dim Prenom As String 
Dim Age As Integer 
Dim Sexe As Gender 
End Structure 
ı; Dim x As Personne 
i x.Nom = "Aloui" 
ı x.Prenom = "Samir" 
i x.Age = "30" 
ı x.Sexe = Gender.Male 


; <Personne> 

<Nom>Aloui</Nom> 
<Prenom>Samir</Prenom> 
<Age>30</Age> 

<Sexe>Male</Sexe> 

; </Personne> 


من ملاحظة بسيطة نجد أنه صنع وسما باسم الهيكل g "Personne"‏ صنع داخله وسوم انما الخصائص و 
ل ل 


ه٠‏ الجداول يتم تمثيلها بوسم أب هو الجدول و داخله وسوم أبناء من أجل كل خلية. يكون هناك وسم فيه النوع و 
القيمة كمثال على ذلك قمت بتعريف جدول من نوع مختلط و هيأته بالقيم التالية: 


tin‏ iاهiهS‏ المتوفرة في الدوت نت. حصلت على النتيجة التالية: 
ı <ArrayOfAnyType>‏ 
<anyType>10</anyType>‏ 
<anyType>20.2</anyType>‏ 
<anyType>true</anyType>‏ 
<anyType>Hello</anyType >‏ : 
</ArrayOFfAnyType >‏ | 


هذه الأنواع يكون التحويل فيها آليا و لا داعي لتدخل المبرمج و هناك أنواع أخرى كأن يكون كائنا مولدا من 
كلاس كل خصائصها من آنواع بسيطة أو من آنواع قابلة للتحويل الآلي أو لأنواع تم معالجة تحويلها يدويا 
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ج: هناك أنواع تستدعي تدخل المبرمج لحفظها مثل القیم من نوع اهاه و ۴٣٤‏ و أخرى أكثر تعقيدا مثل 
Image‏ أو الملفات مثل الملفات الصوتية أو التنفيذية. 


أما النوع مام و النوع "ه۴ فهما يشبهان أي كلاس أو هيكل عادي غير أن السبب لعدم تخزين قيمهما هو 
وجود خاصية في اص× و هي أنه لا يحفظ إلا قيم الخصائص التي تقبل القراءة و الكتابة. أما في الدوت نت فإن 
خصائص ۲٥اه)‏ و ۴٥٣۲‏ هي للقراءة فقط. و للاحتيال على ذلك يجب إنشاء نوع جديد مشابه للنوع الذي نريد 
تخزین قيمه "ه۴ أو هاه و لیکن اسمه o۲اه٤اص×‏ أو ۲٣٥۴اص×‏ متلا و نجعل خصائصه للقراءة و الكتابة 
معا. و عندما نريد الحفظ ننقل القيم من ذلك النوع للنوع الجديد و نحفظ و سيتم تلقائيا و عند القراءة ستتم 
ا ا 


ا اال ال ل ل لل ل 
ال ل 


و أما للأنواع الأكثر تعقيدا كالصور و الملفات الثنائية . فالحل الوحيد هو تحويل المحتوى إلى جدول بايتات 
باستعمال ما يسمى بال هك حيث يمكننا فتح الملف أو الصورة بواسطته بشكل جدول بايتات. إذن نستغل 
هذه الخاصية فنأخذ البايتات و التي قيمها محصورة بين 0 و 255 و نضعها في جدول من نوع )ر8 و هنا 
يكون حفظ الجدول آليا. و في العملية العكسية نقرأ القيم في جدول ثم نملا هه بقيم الجدول و نعيد بعدها 
توليد الملف أو الصورة انطلاقا مما لدينا 


هناك نوع أخير و هو المصفوفات و التي تختلف عن الجداول الخطية و عن جداول الجداول. و السبب في ذلك 
أن علاقة الارتباط في ا»× لها اتجاه واحد فقط. لأشرح أكثر. فحين نقول "لكل شخص اسم" معناه أن الاسم 
متعلق بالشخص و بالتالي سيكون هناك لكل شخص اسم أي أن الوسم ٥۳ھ‏ سیکون ابنا للوسم ٣۶0م‏ و لا 
نجد أبدا علاقة تقول" لكل اسم شخص" و لن يكون أبدا الوسم هءء ابنا للوسم .مصه" أما في المصفوفات 
فهناك متلا × و ۷ أو Rs‏ و ءاه و كل منهما متعلق بالآخر فنقول أن لكل سطر مجموعة أعمدة و نقول أن 
لكل عمود مجموعة أسطر و بالتالي علاقة الأبوة و البنوة في اتجاه واحد غير محققة و بالتالي لا يمكن تمتيلها 


xml. 
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التدخل اليدوي هنا ممكن بحالتين. إما تحويل االمصفوفة من الشكل [ءء...,,ر,»] ألى الشكل [ء1ء....[ء][ر][×] اي 
من مصفوفة إلى جدول جداول حيت كل جدول عناصره هي جداول و كل عنصر من تلك العناصر قد يكون 
أيضا جداول و النهاية تكون قيم قابلة للحفظ الآلي. بهذه الطريقة يكون الحفظ آليا. 


ثم نضيف باراميترات للوسم نحدد فيها عدد الأسطر» عدد الأعمدة» و طريقة الحفظ سطرا بسطر أم عمودا 


بعمود. 


LILI T TTL TT TILT TTL LT TTL TT TTT LT LT TTI DTT TTT TTT TTT TLL TTT LTT TLL TTI LT TTL IT LLL TTL TTT TLD DILL TT TT TTT TLL TTT LTT TILT TTL TIT TLL TTL ITT TTT TTT LCL LT TTD TT TD OLD TL TTT LTT TLL TTT LTT TLL TTT 


ج: هناك بعض القواعد البسيطة في اختيار مكان حفظ قيمة معينة. فقيم الوسوم هي القيم المهمة و الأساسية أما 
قيم البارميترات فهي قيم "نحتاجها في الكواليس" فهي تنظيمية أو توضيحية لأمر ما بخصوص القيم . 


س: هل تعطینا مثالاتو ضیحيا؟ 


ج: لنفرض أنه لدينا مصفوفة مكونة من 5 اعمدة و 4 اسطر مهيئة بقيم عددية. الآن أريد تخزين هذه 
المصفوفة في ملف اص× لو قمنا بكتابة 20 قيمة مع بعض فهذا أمر عادي. لكن لو أرنا قراءة 20 قيمة 
لمصفوفة من ملف إ»× قدمه لناشخص ما فكيف سنعرف هل هي قيم جدول 20×1 أو 10×2 أو 5×4 أو 
5 أو 2×10 أو 1×20 ؟. كل هذه القيم تمثل أبعاد مصفوفات و لكن واحدة فقط هي الصحيحة و لهذا رغم 
أن قيمة عدد الاسطر و الأعمدة ليست "مهمة" و لكنها صارت الآن على درجة من الأهمية بحيث لا يمكننا 
تعريف مصفوفة إلا منهما أو على الأقل بواسطة احداهما. حيث يمكننا تقسيم العدد الكلي على إحداهما لنحصل 
على القيمة الثانية. و منه فقيمة ءام و سه8 لن تكون قيما للوسم مثل قيم خلايا المصفوفة بل ستكون 


بارامیترات تستعمل فی تعریف أبعاد ١‏ لمصفو فة 
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بقي مشكل آخر بعد أن عرفنا ابعاد المصفوفة و هو هل تم التخزين سطرا بسطر أم عمودا بعمود؟ لأن القراءة 
بشكل يخالف طريقة الكتابة سيوؤدي بنا للحصول على مصفوفة لا تشبه أبدا المصفوفة التي قمنا بتخزينها و لهذا 
يلزمنا باراميتر ثالث يخبرنا عن طريقة القراءة و الكتابة. 


يمكن اخذ مثال أخر من 1111 مثلا فنحن نحدد عرض الجدول و ارتفاعه و حجم إطاره و لون خلفيته و لكن 
الاسطر هي المهمة و بالتالي فالقيم السابقة هي (ديكور) تحفظ كباراميترات في وسم الجدول عإاة1. 


EPLIRETTES™ 


ج: حفظ الجداول و القيم ذات الأنواع المركبة يكون على مراحل. فأول مرحلة يجب إضافة وسم سيضم كل القيم و 
الخصائص و بعدها نضيف وسوم بسيطة بها القيم البسيطة او المركبة التي توجد في القيمة المركبة 


1. أولا أضيف وسما و أسمیه مثلا "٥اط‏ ھ2۲" بالدالة † 26۴م و اربطه. 
2. باستعمال حلقة ه۴ من اول خلية لآخر لية في الجدول سأفعل ما يلي 
آ. أنشئ وسما و اسمیھ مثلا "م|ں||ام)" بالدالة "!اع مهم و أربطه مع الوسمع|اbھ "a1‏ 
ب. انشئ قيمة ×٥×‏ و اعطيها قيمة الخلية الحالية ثم اربطها بالوسم ءا اام الذي أنشأته 


~_ 


بهذه الطريقة يمكنني تخزين جدول بايتات فأخزن ملف أو صورة أو أي شيء يمكن تمثيله في جدول 


س: و کبف لو ارت تخزين مصفوفة ذات بعدین يدویا؟ 


ج: لو أردنا تخزين مصفوفة يدويا فهناك طرق عديدة حسب الكيفية التي نريد استعمال الحفظ بها. و سأتناول 3 


E SC 
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OIA 4 FIAT 
E SG ©6 
6E SB GG E E 


ه اول كيفية هي حفظ المصفوفة بشكل سطر واحد. في هذه الحالة يجب علينا: 
ه انشاء وسم جدید نسمیه مثلا "عaMa†r¡cہ"‏ 
مه نضيف باراميترات بها عدد الاسطر و عدد الأعمدة و اتجاه القراءة و الكتابة 
ه تم نقوم بتخزين كل القيم في "نص" و نفصل بينها بالنقطة-فاصلة متلا 


ı <maMatrice rows="3" cols="5" direction="byRow"> 
QFE AEST LOT TOI SLIT STS ET OSES 
; </maMatrice> 


ه ثاني كيفية و هي حفظ كل عنصر في وسم خاص به و هنا يجب علينا: 
ه انشاء وسم جدید نسمیه متلا "عaMar¡|cہ"‏ 
مه نضيف باراميترات بها عدد الأسطر و عدد الأعمدة و اتجاه القراءة و الكتابة 
ه باستعمال حلقة تكرارية من أول خلية لآخر خلية (حلقتين ٤٥١‏ واحدة على الأسطر و الأخرى 
على الأعمدة حسب ما حددناه في براميتر الاتجاه) نقوم بما يلي: 
ننشئ وسم جدید و لیکن اسمهھ "ءاں‌اام)" و نربطه بالوسم عc¡ "2Ma‏ 
» ننشئ قيمة بها قيمة الخلية الحالية و نربطها بالوسم مں اام الذي أنشأناه آخرا. 


MaMa icê Fos 3 coli" direction by fol )g TT 
<Cellule>O0</Cellule> 
<Cellule>13</Cellule> 
<Cellule>4</Cellule> 
<Cellule>12</Cellule> 
<Cellule>10</Cellule> 
<Cellule>10</Cellule> 
<Cellule>9</Cellule> 
<Cellule>3</Cellule> 
<Cellule>19</Cellule> 
<Cellule>7</Cellule> 
<Cellule>3</Cellule> 
<Cellule>81</Cellule> 
<Cellule>6</Cellule> 
<Cellule>5</Cellule> 
<Cellule>15</Cellule> 

</maMatrice> 
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م ا ر لال ا ی ا ل ار ا 


ه إنشاء وسم جدید نسمیيه مٽں "maMatrice"‏ 
ه باستعمال حلقة تكرارية على الاسطر نقوم بما يلي: 
ننشئ وسم جدید نسمیه مثلا "٥وا"‏ و نربطه بالوسم "2Ma‏ 
٠‏ (يمكننا الآن استعمال طريقة دمج كل قيم السطر في نص أو يمكننا حفظ كل قيمة 
منفصلة و هاته سأستعملها) 
» باستعمال حلقة تكرارية على كل قيمة في السطر نقوم بما يلي: 
» ننشئ وسما جدیدا نسمیه م‌اں‌اام) و نربطه بالوسم ٠و1‏ الذي أنشاتاه آخرا. 


» ننشئ قيمة و نضع به قيمة الخلية الحالية و نربطها بالوسم عاںاام) 


iı <maMatrice> 
<Ligne> 
<Cellule>O0</Cellule> 
<Cellule>13</Cellule> 
<Cellule>4</Cellule> 
<Cellule>12</Cellule> 
<Cellule>10</Cellule> 
</Ligne> 
<Ligne> 
<Cellule>10</Cellule> 
<Cellule>9</Cellule> 
<Cellule>3</Cellule> 
<Cellule>19</Cellule> 
<Cellule>7</Cellule> 
</Ligne> 
<Ligne> 
<Cellule>3</Cellule> 
<Cellule>81</Cellule> 
<Cellule>6</Cellule> 
<Cellule>5</Cellule> 
<Cellule>15</Cellule> 
۰ </Ligne> 
ı </maMatrice> 


يمكن استعمال الحفظ عمودا بعمود أيضا بنفس الطريقة. تقنيا فلو كنا سنقوم بالقراءة اليدوية فالأحسن اختيار 
الكيفية الثانية لأن هذه الكيفية تسمح لي بمعرفة عدد الأسطر و الأعمدة من البداية فأستطيع مباشرة تعريف 
أبعاد المصفوفة عند التصريح بها كما أنني أستطيع استعمال حلقتي ۴٠۲‏ لقراءة القيم طالما أنني أعرف قيم 
التوقف للحلقة. 
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سلسلة "سين؟... جيم" | ]حول 11× الجزء الثاني[ 


قیم هذا النوع هي قيم نصية مثل قيم ×٠×‏ و لكن السبب في إضافتها هي كونها تستطيع حفظ النص 
تماما كما هو دون ترجمته . 


سنام 4 


ج: كما نعلم فالملف ا» هو ملف نصي و لكي يتعرف عليه ال میم" فإنه يستخر ج الكلمات المحصورة بين 
< و > لیعتبرها ٤|٥6‏ و يستخرج أيضا الباراميترات و يتعرف على التعاليق ب <! -- و غيرها من 
الر موز الى تيح له فصل الكلمات المفتاحيا س الق 


لكن ماذا لو أردنا تخزين جملة تحتوي على وسوم كأن نريد حفظ ملف إ"» كعنصر أو نريد حفظ صفحة 
٠|‏ كعنصر. أو نريد حفظ أي شيء يكون فيه وسوم أو بعض الرموز التي قد تكون رموز مفتاحية ل |». 
فلو حفظناها في ×٠×‏ فسيتم ترجمة تلك الكلمات لاحقا و بدل أن تكون نصا ستعتبر وسوم جديدة و سيقع 
تأثير ها على الملف ككل و قد يصبح الملف خاطئا في حال وجود محتوی ترجمه کوسم مفتوح بینما لا يوجد 
وسم يغلقه مثلا. 


لهذا السبب بالدات جاء النوع C0۸1۸‏ و وسمه يدعىی ١٥ایوم‌؟ةtة٥٤٣|اص»×‏ و يتم توليده بالعبارة 
CreateCDat Session‏ حیث يمکننا تخزین آي شيء به حتی لو کان نصا لملف ام× آخر. و عند القراءة فإن 


EF 1 
a 0. 


إلى هنا نأتي لنهاية أول موضوع من السلسلة . في انتظار ملاحظاتكم» مشاركاتكم و انتقاداتكم استودعكم الله 
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